Page({
  data: {
    name: '',
    gender: 1,
    mobile: '',
    idcardFrontUrl: '',
    idcardBackUrl: ''
  },
  onLoad({ point, building, room, houseId }) {
    if (houseId) {
      // 编辑
      this.getHouseDetail(houseId)
      // 点击修改信息后，动态的渲染标题
      wx.setNavigationBarTitle({
        title: '修改房屋信息'
      })

    } else {
      // 添加
      // point 上个页面传过来的小区名
      // building 上个页面传过来的楼栋号
      // room 上个页面传过来的房间号
      // houseId 上个页面传过来的房屋id
      this.setData({
        point,
        building,
        room
      })
    }
  },
  // 调用获取房屋详情数据的接口，做数据的回显
  async getHouseDetail(id) {
    const { code, data } = await wx.http.get(`/room/${id}`)
    if (code !== 10000) return wx.utils.toast()
    // 调用接口成功
    this.setData({
      ...data
    })
  },
  // 验证业主姓名
  validName() {
    // 验证业主姓名（必须为汉字）
    const reg = /^[\u4e00-\u9fa5]{2,5}$/
    // 验证业主姓名
    const valid = reg.test(this.data.name.trim())
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写真实中文姓名!')
    // 返回验证结果
    return valid
  },
  // 验证手机号
  validMobile() {
    // 验证手机号
    const reg = /^1[3-8]\d{9}$/
    const valid = reg.test(this.data.mobile.trim())
    // 验证结果提示
    if (!valid) wx.utils.toast('请填写正确的手机号码!')
    // 返回验证结果
    return valid
  },
  // 身份证照片的校验
  validPictrue() {
    const valid = !!this.data.idcardFrontUrl && !!this.data.idcardBackUrl
    // 验证结果提示
    if (!valid) wx.utils.toast('请选择身份证正反面照片')
    // 返回验证结果
    return valid
  },
  // 上传身份证照片
  async uploadPicture(ev) {
    // 接受事件传参
    // console.log(ev.mark.type);
    // 选择图片
    await wx.chooseMedia({
      // 最多可以选择的文件个数
      count: 1,
      // 文件类型
      midiaType: ['image'],
      // 是否压缩所选文件，是不是原图
      sizeType: ['compressed'],
      // 回调函数，返回结果
      success: (res) => {
        // console.log(res.tempFiles[0].tempFilePath, '图片临时地址');
        // 将上一步返回回来的临时图片，上传给服务器，并显示在页面上
        // 调用接口
        wx.uploadFile({
          url: wx.http.baseURL + '/upload',
          // 要上传的文件资源的路径（本地路径）
          filePath: res.tempFiles[0].tempFilePath,
          // 文件对应的key
          name: 'file',
          // 请求头
          header: {
            Authorization: getApp().token
          },
          success: (res) => {
            console.log(res, '上传文件返回的消息');
            // 对返回的JSON数据，进行反序列化
            // console.log(JSON.parse(res.data));
            const url = JSON.parse(res.data).data.url
            // 对url进行判断
            if (ev.mark.type === 'idcardFrontUrl') {
              // 点击的是身份证正面
              this.setData({
                idcardFrontUrl: url
              })
            } else {
              // 点击的是身份证反面
              this.setData({
                idcardBackUrl: url
              })
            }
          }
        })
      }
    })
  },
  removePicture(ev) {
    // 移除图片的类型（身份证正面或反面）
    const type = ev.mark.type
    this.setData({
      [type]: ''
    })
  },
  // 点击提交审核
  async submitForm() {
    // 校验用户名
    if (!this.validName()) return
    // 校验手机号
    if (!this.validMobile()) return
    // 校验身份证照片
    if (!this.validPictrue()) return
    // 删除 this.data中的多余的属性
    delete this.data.__webviewId__
    delete this.data.status
    // 提交我的房物页信息
    const { code } = await wx.http.post('/room', this.data)
    // console.log(res, '提交房屋信息返回的页面');
    if (code !== 10000) return wx.utils.toast()

    // 成功后跳转至房屋列表
    wx.navigateBack({
      delta: this.data.id ? 2 : 4
    })
  }
})
